ENTRY OF FILE NUMBER AND/OR OTHER 
]\0J IDENTIFICATION INFO, AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 



112. 



114 



CHECK PRINTED ON WORKSTATION 
PRINTER, AND MAILED TO PATENT 
AND TRADEMARK OFFICE 



PTO RECEIVES 
CHECK AND CASHES 
AGAINST BANK ACCOUNT 



120 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



126 




INFORMATION REGARDING 
CHECKS PRINTED UPLOADED 
TO CENTRAL OFFICE 
BY REMOTE WORKSTATION 



122- 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



BANK SENDS TO 
CENTRAL OFFICE 

MONTHLY STATEMENT 
OF TRANSACTIONS 

TO CENTRAL OFFICE 



128 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



RG. 1A 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
LAW FIRM 



136 




BILL DUE 
IN 90 DAYS OR 
• OTHER PERIOD 


146 





132 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS • 



138 
_i 



SEND INVOICE 
TO CLIENT (8Y 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 



140 , 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


142 




LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 


144 , 




LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE . 



FIG. 1B 



210- 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO, AND REQUESTED 
AMOUNT INTO REMOTE WORKSTATION 



212. 



WORKSTATION ISSUES AUTHORIZATION 
CODE FOR DEBIT OF REQUESTED 
AMOUNT FROM DEPOSIT ACCOUNT 



213- 



214 



I 



TRANSMITTAL INCLUDING AUTHORIZATION 
CODE SENT TO EPO/PCT 
(DEPOSIT ACCOUNT AUTHORIZATION) 



EPO/PCT RECEIVES 
TRANSMITTAL AND DEBITS 
DEPOSIT ACCOUNT 



220 
L_ 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



226 




INFORMATION REGARDING 
AUTHORIZATION UPLOADED 
TO CENTRAL OFFICE 8Y WS 



218. 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
8Y WORKSTATION 



CENTRAL OFFICE RECEIVES 
MONTHLY STATEMENT OF 
ACCOUNT DE8ITS 
IDENTIFIED BY 
AUTHORIZATION CODE 



228 




CENTRAL OFFICE' RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



FIG. 2A 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



236 



BILL DUE 
IN 90 DAYS OR 
OTHER PERIOD 



246 
_J 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
LAW FIRM 



232 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 



238 

i 

SEND INVOICE 
TO CLIENT (BY 
LAW FIRM) AT 
END OF MONTH 

OR OTHER PERIOD 



240 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


242 




LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 


244 




LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



FIG. 2B 
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ENTRY OF FILE NUMBER AND/OR OTHER 
3 10 J IDENTIFICATION INFO, AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 





311- 


WORKSTATION ELECTRONICALLY 
CONTACTS CENTRAL OFFICE FOR 
CONFIRMATION/APPROVAL 




312- 






TO STEP 


WORKSTATION ISSUES CHECK 


120 OR 220 




OR AUTHORIZATION CODE 




313- 






TO STFP 


CODE OR CHECK SENT 


H4 OR 214 


TO PATENT AGENCY 




TO STEP 
122 OR 222 



FIG. 3 
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410 



UW FIRM 



418 



ACCOUNTING/ 
BILLING 
SYSTEM 



^422 



CHECK 
PRINTING/ 
AUTH. CODE 
SYSTEM 



? 

416 



434 



420 



412 
— S 



PATENT 
AND 
TRADEMARK 

PAYMENT 
FEE SYSTEM 



432 _ 



424 
_i 



426 



PATENT 
AGENCY 



428 
\ 



414 
_i 



430 



ACCOUNT 



PATENT AGENCY 
OR FINANCIAL 
INSTITUTION 



FIG. 4 
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July 22, 1997 Payee: U.S. Potent & Trademark Office 

Fee Code: 101/20! 8astc rUing Fee-Utility 
Oient Number: 0O997 
Matter Number xxxx 

Note: This requires special attention. 




July 22, 1997 

Two Thousand AND 0/100 DOLLARS 
LIS. Patent & Trademark Office 


$ 2,000.0 


FIG. 18 


PTO Management Company Invoice 

Invoice Date: July 22, 1997 


Item: 

Check Number 1511 
From Account: 

58-67-9785 - PTFM Checks for U.S. PTO 
Request by: 

Brian Larson on: 07/22/1997 12:53:16 " 
Client Number. 00997 Matter Number xxxx 
Note: This requires special attention. 




Check Amount: 
Fee: 


$ 2,000.0 
1 118.75 


Total Due By 09/20/1997: 


$ 2,118.75 


Discounted Total Due If Paid 8y 08/11/1997: 
Discounted Total Due If Paid By 08/11/1997: 


$ 2,029.69 
$ 2.059.38 



FIG. 19 



Deposit Account Authorization 


PTFM EPO Oeposit Account 


Account Number XYZ234784 


Authorization Number. SLWK00021023 




Dote Fee Code 


Check Amount 


July 22. 1997 sdhfsfd 


$ mo 


Poyee: European Patent Office 




Requested by: Brian Larson 


on: 07/22/1997 t2:44:l8 


Client Number 00999 




Matter Number sfgs 


Fee Assessed:] $6.75 



FIG. 20 



PTO Management Company Invoice 

Invoice Date: July 22, 1997 


Item: . 

Automation Number: SLWK00021023 
From Account: 

XYZ234784 - PTFM EPO Oeposit Account 
Request by: 

Brian Larson on: 07/22/1997 12:53:16 
Client Number 00999 Matter Number, xxxx 




Authorization Amount: 


$ 300.0 


Fee: 


$ 6.75 


Total Due By 08/21/1997: 


$ 306.75 | 





FIG. 21 
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Database: PTFM 



Structure for table: 
Number of data records : 
Date of last update: 
Code Page: 



Field 


Field Name 




Width 


1 


AC CODE 




8 


2 


AC NAME 




30 


3 


AC CLIENTNUM. 




10 


4 


AC CLIENTNAM. 




50 


5 


AC ACCOUNTNU. 




20 


6 


AC ACCOUNTTY. 




18 


7 


AC BALANCE 




12 


8 


AC NEXTCHECK 




10 


** Total ** 




159 


Structure 


for table: 


Number of 


data records: 


Date of last update: 


Memo file 


block size: 


Code Page: 


Field 


Field Name" 




Width 


1 


AT_TYPE 




18 


2 


AT KEEPBALAN. 




1 


3 


ATJTRANSTYPE . 




4 


4 


AT__PAYEES 




4 


5 


AT_CANEXCEED 




1 


6 


AT CHARGE FEE 




1 



C : \PMCSOURCB\ACCOUNT . DBF 

9 

07/15/1997 
1252 



Type 




Index Collate 


Nulls 


Character 




Asc Machine 


No 


Character 




Asc Machine 


No 


Character 






No 


Character 






No 


Character 






No 


Character 






No 


Numeric 






No 


Numeric 






No 



C : \ PMCSOURCE\ACCTTYPE . DBF 

9 

06/10/1997 
64 

1252 

Type 

Dec Index Collate Nulls 

Character 

No 

Logical 

No 

Memo 

No 

Memo 

No 

Logical 

No 

Logical 

No 



FIG. 24A 



7 


AT CHECKONLY 
1 


Logical 


No 


8 


ATJUJTHORIZA. . 
1 


Logical 


No 


9 


AT USPTOCODE 
1 


Logical 


No 


10 


AT EPOCODE 
1 


Logical 


No 


11 


AT EXPORTTOP. . 
1 


Logical 


No 



** Total ** 



Structure for table: 
Number of data records : 
Date of last update: 
Code Page : 

Field Field Name 
Width 

1 CL_CLIENTNUM. 

10 

2 CL_NAME 

50 

3 CL_PLAN 

20 



C : \PMCSOURCE\CLIENT . DBF 



** Total ** 



81 



Structure for table: 
Number of data records: 
Date of last update: 
Memo file block size: 
Code Page : 

Field Field Name 
Width 

1 DE__CODE 

8 

2 D E_CL I ENTNUM . 

20 

3 DE_MATTERNUM. 

20 • 

4 DE_DATETIME 

8 

5 DE__TRANS ACT I . 

3 



06/20/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 



Nulls 
No 
No 
No 



C : \PMCSOURCE\DETAIL . DBF 

69 

07/15/1997 
64 

1252 

Type 

Dec Index Collate 

Character 



Character 
Character 
DateTime 
Character 



Nulls 
No 
No 
NO 
No 
No 



FIG. 24B 



6 DE_PAYEE 

50 

7 DE_PTOCODE 

75 

8 DE_AMOUNT 

10 2 

9 DE_PLUSMINUS 

2 

10 DE_WHO 

25 

11 DE_LOCAT I ON 

10 

12 DE_CHECKNUMB . . 

10 

13 DE_NOTES 

4 

14 DE_FEE1 

8 2 

15 DEJDATEDUE1 

8 

16 DE_FEE2 

8 2 

17 D E_DAT EDUE 2 

8 

18 DE_FEE3 

8 2 

19 DE_DATEDUE 3 

8 

20 DE_STATUS 

17 

21 DE_SELECTED 

1 

22 DE_PRINTDATE . . 

8 

23 DE_EXPORTDAT. . 

8 

** Total ** 

328 



C Vi a t*s r* ^ o T* 








fH arart" or 






NO 


ll U11ICX. J.L- 






XT—. 

WO 


IN LI me? I1C 






NO 


\— ileal, a^uci 






NO 


LIldldLCci 






No 


IMUtUcXlL 






No 


Memo 






No 


JNUIUCIXC 






No 


Date 






No 


XT 

Numeric 






No 


Date 






No 


Numeric 






No 


Date 






No 


Character 






No 


Logical 






No 


DateTime 






No 


DateTime 





Structure for table: C:\PMCSOURCE\PTOCODE.DBF 
Number of data records: 14 9 

Date of last update: 05/16/1997 
Code Page: 1252 

Field Field Name Type 

Width Dec Index Collate Nulls 



FIG. 24C 



1 

2 

** Total ** 



PT_CODE 
75 

PTJJSPTOCODE 
1 

77 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 



Character 
Logical 



C : \PMCSOURCE\RATE . DBF 

48 

06/27/1997 
1252 



No 
No 



jld 


Field Name 




Type 






Width 


Dec 


Index Collate 


Nulls 


l 


RA PLAN 
20 




Character 


No 


2 


RA LOWERLIMI . . 




Numeric 






8 


2 




No 


3 


RA UPPERLIMI . . 




Numeric 






8 


2 




No 


4 


RA DAYSDUE1 
3 




Numeric 


No 


5 


RA AMOUNT 1 




Numeric 






8 


2 




No 


6 


RA DAYSDUE2 
3 




Numeric 


No 


7 


RA AMOUNT 2 




Numeric 






8 


2 




NO 


8 


RA DAYSDUE3 
3 




Numeric 


No 


9 


RA AMOUNT 3 




Numeric 






8 


2 




No 


10 


RA NOT AL LOWE . . 
1 




Logical 


No 



** Total ** 



71 



Structure for table: 
Number of data records : 
Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 

Width Dec 
1 SU_ITEM 
20 



C : \PMCSOURCE\SETUP . DBF 

10 

07/22/1997 
64 

1252 

Type 

Index Collate Nulls 
Character 

No 



FIG. 24D 



2 SU_NUMBER 

10 

3 SU_DATA 

4 

** Total ** 

35 



Numeric 
Memo 



No 
No 



Structure for table : 
Number of data records: 
Date of last update: 
Code Page: 



C : \PMCSOURCE\TRANTYPE . DBF 



06/10/1997 
1252 



Field 


Field Name 


Type 






Width Dec 


Index Collate 


Nulls 


1 


TR TRANSACT I . . 
3 


Character 


No 


2 


TR DESCRIPTI. . 
20 


Character 


No 


3 


TR PLUSMINUS 
2 


Numeric 


No 


4 


TR CHKACCTVA . . 
1 


Logical 


No 


5 


TR AUTACCTVA. . 
1 


Logical 


No 


6 


TR CHKLIMITE. . 
1 


Logical 


No 


7 


TR AUTLIMITE . . 
1 


Logical 


No 


8 


TR CHARGEFEE 
1 


Logical 


No 



** Total ** 



31 



Structure for table : 
Number of data records: 
Date of last update: 
Code Page: 

Field Field Name 
Width 

1 US_ID 

20 

2 US_LAST 

15 

3 US_FIRST 

15 

4 US_PAS SWORD 

15 



C : \PMCSOURCE\USER . DBF 



05/02/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 

Character 



Nulls 
No 
No 
No 
No 
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5 


USJTHECKBALA. . 


Logical 


NT/-\ 

NO 


6 


US_VIEWREQUE. . 
1 


Logical 


No 


7 


US_CREATEREQ . . 
1 


Logical 


No 


8 


US_CANCELREQ . . 
1 


Logical 


No 


9 


US MODI FYACC . . 
1 


Logical 


No 


10 


US_PRINTREPO . . 
1 


Logical 


No 


11 


US EXTRACTDA. . 
1 


Logical 


No 



** Total ** 

73 



Program File: MAIN. PRG 

_SCREEN. Width = 633 
^SCREEN. Height =418 
_SCREEN.Icon = "opening . ico" 

SET CENTURY ON 

SET BELL OFF 

SET CONFIRM ON 

SET DELETED ON 

SET MULTILOCKS ON 

SET PROCEDURE TO MAIN. PRG 

OPEN DATABASE PTFM 

PUBLIC frmMenu, gcLoginID, gcFullName, gcLocation, gcProgName 

USE Setup 

SET ORDER TO Item 

IF SEEK ( n PROGNAME n ) 

gcProgName = TRIM (Setup . SU_Dat a) 

_SCREEN. Caption = gcProgName 

ELSE 

gcProgName = "Patent & Trademark Fee Management" 

END IF 

IF SEEK ( " LOGINID " ) 

gcLoginID = TRIM (Setup. SUJDat a) 

ELSE 

gcLoginID = "Unknown" 



FIG, 24F 
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END IF 

IF SEEK ( " FULLNAME n ) 

gcFullName = TRIM (Setup . SU_Data) 

ELSE 

gcFullName = "Unknown" 

END IF 

IF SEEK ( "LOCATION" ) 

gcLocation = TRIM (Setup. SU_Data) 

ELSE 

gcLocation » "Unknown" 

ENDIF 

CLOSE TABLES ALL 

DO FORM Menu NAME f rmMenu 

READ EVENTS 

************************************* 
FUNCTION GetDueDate 

* Finds the Monday which is the specified number of weeks after 

* the date the request was made. If the request was made on a 

* Monday, do not count that Monday. 
LPARAMETERS ldDate, InNumMondays 

Local InMondayCnt 

InMondayCnt = 0 

DO WHILE InMondayCnt < InNumMondays 
ldDate = ldDate + 1 
IF DOW (ldDate, 2) = 1 

InMondayCnt = InMondayCnt + 1 

ENDIF 

ENDDO 

RETURN ldDate 

************************************* 
FUNCTION TextDollar 

PARAMETERS nNumber 

LOCAL InDollars, InCents 

InDollars = INT (nNumber) 

InCents = (nNumber - InDollars) * 100 



FIG. 24G 



RETURN TextNumeric (InDollars) + "AND " +STR ( InCent s,2)+"/100 
DOLLARS" 

************************************* 

FUNCTION TextNumeric 

PARAMETERS nNumber 

LOCAL lcString, InWorkNumber 

InWorkNumber = nNumber 
lcString = " " 

IF InWorkNumber >= 1000000 

lcString - TextNumeric (InWorkNumber/ 1000 000) + "Million " 

InWorkNumber = InWorkNumber - 
(INTdnWorkNumber/1000000) *1000000) 
ENDIF 

IF InWorkNumber >= 1000 

lcString - lcString + TextNumeric (InWorkNumber/ 1000) + 
"Thousand " 

InWorkNumber = InWorkNumber - (INT (InWorkNumber/ 1000) * 1000) 

ENDIF 
DO CASE 

CASE InWorkNumber >= 900 

lcString = lcString + "Nine Hundred n 

InWorkNumber o InWorkNumber - 900 
CASE InWorkNumber >= 800 

lcString = lcString + "Eight Hundred " 

InWorkNumber = InWorkNumber - 800 
CASE InWorkNumber >= 700 

lcString = lcString + "Seven Hundred " 

InWorkNumber = InWorkNumber - 700 
CASE InWorkNumber >= 600 

lcString = lcString + "Six Hundred " 

InWorkNumber = InWorkNumber - 600 
CASE InWorkNumber >= 500 

lcString = lcString + "Five Hundred " 

InWorkNumber = InWorkNumber - 500 
CASE InWorkNumber >= 400 

lcString = lcString + "Four Hundred " 

InWorkNumber = InWorkNumber - 400 
CASE InWorkNumber >= 300 

lcString » lcString + "Three Hundred " 

InWorkNumber = InWorkNumber - 300 
CASE InWorkNumber >= 200 
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IcString = lcString + "Two Hundred 
InWorkNumber ■ InWorkNumber - 200 

CASE InWorkNumber >= 100 

IcString - lcString + "One Hundred 
InWorkNumber = InWorkNumber - 100 

END CASE 

DO CASE 

CASE InWorkNumber >= 90 

lcString = lcString + "Ninety " 
InWorkNumber = InWorkNumber - 90 

CASE InWorkNumber >= 80 

lcString = lcString + "Eighty n 
InWorkNumber = InWorkNumber - 80 

CASE InWorkNumber >= 70 

lcString = lcString + "Seventy " 
InWorkNumber = InWorkNumber - 70 

CASE InWorkNumber >= 60 

lcString = lcString + "Sixty " 
InWorkNumber = InWorkNumber - 60 

CASE InWorkNumber >= 50 

lcString = lcString + "Fifty " 
InWorkNumber = InWorkNumber - 50 

CASE InWorkNumber >= 4 0 

lcString = IcString + "Forty " 
InWorkNumber = InWorkNumber - 40 

CASE InWorkNumber >= 30 

lcString = lcString + "Thirty " 
InWorkNumber = InWorkNumber - 30 

CASE InWorkNumber >= 20 

lcString = lcString + "Twenty " 
InWorkNumber = InWorkNumber - 20 

CASE InWorkNumber >= 19 

lcString = lcString + "Nineteen " 
InWorkNumber = InWorkNumber - 19 

CASE InWorkNumber >= 18 

lcString = lcString + "Eighteen " 
InWorkNumber = InWorkNumber - 18 

CASE InWorkNumber >= 17 

lcString = lcString + "Seventeen " 
InWorkNumber = InWorkNumber 17 

CASE InWorkNumber >= 16 

lcString = lcString + "Sixteen " 
InWorkNumber « InWorkNumber - 16 . 

CASE InWorkNumber >= 15 

lcString = lcString + "Fifteen " 
InWorkNumber = InWorkNumber - 15 
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CASE InWorkNumber >= 14 

lcString = lcString + "Fourteen " 
InWorkNumber = InWorkNumber - 14 

CASE InWorkNumber >= 13 

lcString = lcString + "Thirteen " 
InWorkNumber « InWorkNumber - 13 

CASE InWorkNumber >= 12 

lcString = lcString + "Twelve n 
InWorkNumber = InWorkNumber - 12 

CASE InWorkNumber >= 11 

lcString = lcString + "Eleven " 
InWorkNumber = InWorkNumber - 11 

CASE InWorkNumber >= 10 

lcString = lcString + "Ten " 
InWorkNumber = InWorkNumber - 10 

ENDCASE 

DO CASE 

CASE InWorkNumber >= 9 

lcString = lcString + "Nine " 
InWorkNumber = InWorkNumber - 9 

CASE InWorkNumber >= 8 

lcString = lcString + "Eight " 
InWorkNumber = InWorkNumber - 8 

CASE InWorkNumber >= 7 

lcString = lcString + "Seven " 
InWorkNumber = InWorkNumber - 7 

CASE InWorkNumber 6 

lcString ■ lcString + "Six " 
InWorkNumber = InWorkNumber - 6 

CASE InWorkNumber >= 5 

lcString = lcString + "Five " 
InWorkNumber = InWorkNumber - 5 

CASE InWorkNumber >= 4 

lcString = lcString + "Four " 
InWorkNumber = InWorkNumber - 4 

CASE InWorkNumber >= 3 

lcString = lcString + "Three " 
InWorkNumber = InWorkNumber - 3 

CASE InWorkNumber >= 2 

lcString = lcString + "Two " 
InWorkNumber = InWorkNumber - 2 

CASE InWorkNumber >= 1 

lcString = lcString + "One n 
InWorkNumber = InWorkNumber - 1 

ENDCASE 
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IF EMPTY(lcString) 
lcString = "No 

ENDIF 

RETURN lcString 



PIG. 24K 



